home *** CD-ROM | disk | FTP | other *** search
/ FM Towns: Free Software Collection 10 / FM Towns Free Software Collection 10.iso / ms_dos / tool / ct / ct.doc next >
Text File  |  1995-02-26  |  14KB  |  322 lines

  1.            -------------
  2.               CTsの使い方
  3.            -------------
  4.  
  5. 1.CTsがすること。
  6.     本プログラムは、NIFTYのログを参照して、そのコメントツリーを
  7.    表示する物です。
  8.     1つの会議室で5040個までの発言についてツリーを作ることが出来
  9.    ます。それ以上の発言は扱えませんので、生ログファイルを削除したり
  10.    (危険!)、検索するディレクトリを少なくするようにして下さい。
  11.     本来は、フォーラムの会議室の発言とPATIOの発言だけを処理すれ
  12.    ば良いのですが、追加機能として以下の処理も行えるようにしました。
  13.       ・HPの発言
  14.       ・メール
  15.       ・データライブラリー(以下DLと略す)のリスト
  16.       ・今週のお知らせ
  17.       ・クリッピングサービス
  18.       ・NIFTYの利用料金情報
  19.     ただし、これらの発言等は、発言日時、発言番号の順に並んだ物として表
  20.    示されます。
  21.     また、DLは、発言番号の位置にDL番号を表示し、DL番号の順に表示
  22.    し、リストの参照数の和が異なれば異なる物として表示します。(参照数の
  23.    和の多い方が後に表示されます。)
  24.     また、課金情報は、発言番号の位置に、1番目の月を表示し、3ヵ月のア
  25.    クセス回数の和が異なれば異なる物として表示します。(アクセス回数の和
  26.    の多い方が後に表示されます。)
  27.     処理の途中で「ESC」キーを押すと、処理を中断します。中断した時、内
  28.    部で使用しているTMPファイル(後述)は削除しません。
  29.  
  30.     今回、「ファイル・インデックス」の考え方を取り入れました。その為、
  31.    かなりたくさんのインデックス・ファイルをディスク上に作ることになりま
  32.    した。
  33.  
  34.     処理内容が増えたため、以前の ctt.exe を分割せざるをえなくなりました。
  35.    以前の ctt.exe を分割して ctm.exe, ctt.exe, ctl.exe ができます。
  36.     プログラムを分割した為、それぞれのプログラムをロードするのに時間が
  37.    かかるようになってしまいました。
  38.     以前からの互換性を守るため、全ての処理は ctd.com を介して行うように
  39.    して下さい。
  40.     ctd.com はコマンドラインをそのまま ctm.exe ctt.exe ctl.exe に渡します。
  41.  
  42.  
  43.  (1) 扱うファイル
  44.    CTsが理解できるファイルは、次のファイルです。
  45.    ┌───────────────────────────┐
  46.    │・FAPXを使ってオートでダウンした「生ログファイル」│
  47.    │・CATLOGを使って「整理したファイル」      │
  48.    └───────────────────────────┘
  49.    これ以外のファイルは、フォーラム名や、HP・PATIOの設置者IDが
  50.   「UNKNOWN」として処理されたり、PATIOがフォーラムとして処理される
  51.   おそれがあります。
  52.    また、全く発言を見つけることができないかも知れません。
  53.  
  54.  (2) 無視するファイル
  55.    CTsが無視するファイルは、明らかにログファイルではないと思われる拡
  56.   張子のファイルです。
  57.    コマンドライン上で、
  58.      ctm
  59.   と実行していただくと、無視するファイルの拡張子が表示されます。
  60.  
  61.  (3) 作成するファイル
  62.    CTsを実行すると「出力ディレクトリ(OutDir)」(後述)に次のファイル
  63.   を作成します。ファイルの内容については後述します。
  64.  
  65.   ・comtree.tmp   コメントツリーの諸データが書き込まれます。
  66.    ・comtree0.tmp  コメントツリーの標題が書き込まれます。
  67.    ・comtxt.tmp   発言の本体が書き込まれます。
  68.    ・会議室.tmp   フォーラムの会議室の一覧が書き込まれます。
  69.    ・DL.tmp    DLの一覧が書き込まれます。
  70.  
  71.  (4) MS-DOSの環境変数の参照
  72.   CTsは、次の2つの環境変数を参照しています。
  73.       ctusr
  74.       tmp
  75.    「ctusr」は、CTsに対してオプションスイッチを設定する働きがあります。
  76.   スイッチの意味はコマンドラインで指定するスイッチと全く同じです。
  77.    ただし、スイッチの優先順序があります。
  78.    優先順位が一番高いのはコマンドラインからの指定です。ここで、指定す
  79.   ると環境変数で指定していても無視されます。
  80.    優先順位が次に高いのは、環境変数「ctusr」での指定です。これは、CTs
  81.   のデフォルトの値を無視します。
  82.    優先順位が最も低いのは、CTsのデフォルトの値です。
  83.  
  84.    「tmp」は、CTsが内部で作成するTMPファイルを書き出すドライブ:デ
  85.   ィレクトリを指定します。この設定がない場合はCTsを起動した時のカレント
  86.   ディレクトリにTMPファイルが書き出されます。
  87.     「tmp」をRAMディスクに設定しておくと処理が高速になります。
  88.  
  89.  
  90. 2.CTsの実行の仕方
  91.    コマンドライン上で、次のように実行して下さい。
  92.     ctd [-option] [-o OutDir名] InputDir名 [InputDir名] [InputDir名]...
  93.   または、
  94.     ctd [-option] [-o OutDir名] File名 [File名] [File名]...
  95.   または、
  96.     ctd [-option] @Def-File名
  97.  
  98.    オプションには必ず「-」を使って下さい。
  99.  
  100.    今回採用した「ファイルインデックス」の考え方により、「-s<DirName>」オ
  101.   プションの指定が大事になります。これをコマンドラインの最初の方で指定して
  102.   下さい。なお、コマンドラインで毎回指定するのは「面倒だ」と思われる方はM
  103.   S-DOSの環境変数「ctusr」に次のようにして「-s<DirName>」を設定して下
  104.   さい。
  105.    >set ctusr=ADsi:\system
  106.    これは、「i:\system」をファイルインデックスを置くディレクトリとすると
  107.   いうものです。
  108.    なお、「-s<DirName>」の指定は、絶対パス指定で行って下さい。また、ファイ
  109.   ルの性格上、RAMディスクには設定しないです下さい。
  110.  
  111.    「-」の後ろには複数のオプションを指定することができます。
  112.      例: -TDo
  113.    また、別々に指定することもできます。
  114.      例: -T -D -o
  115.    また、矛盾する指定を同時に指定した場合は、後で(右側で)指定した方が
  116.   有効になります。
  117.      例: -Todt
  118.        この場合「t」が有効になります。
  119.    「-」の無いものは入力するファイル名かディレクトリ名として判断します。
  120.    ということは、逆に、「-」から始まるファイルやディレクトリは入力として
  121.   扱えないということです。適当な名前に変更(rename)してCTsを起動して下
  122.   さい。
  123.  
  124.    「-o OutDir名」の指定が無い場合は、「comtree.tmp」「comtree0.tmp」
  125.   「会議室.tmp」「DL.tmp」ファイルはカレント・ディレクトリに書き出されま
  126.   す。
  127.  
  128.    オプションについては ctd.com ctm.exe ctt.exe ctl.exe を引数指定無しで
  129.   起動して下さい。簡単な説明が表示されます。
  130.  
  131.  
  132. 3.「入力ディレクトリ(InputDir)」「出力ディレクトリ(OutDir)」について
  133.  (1) 入力ディレクトリ(InputDir)
  134.   ログ・ファイルがどのドライブ:ディレクトリにあるのか指定します。
  135.   指定の仕方はMS-DOSの方法です。
  136.   カレント・ディレクトリのファイルを検索するのであれば「.」を指定します。
  137.   この部分にファイル名を指定すると、指定したファイルだけを読み込んで発
  138.  言を探索します。
  139.   MS-DOSのワイルド・カードが使用できます。
  140.   設定を省略することはできません。
  141.   ディレクトリ名の最後に「\」を付ける必要はありません。
  142.  
  143.  (2) 出力ディレクトリ(OutDir)
  144.   CTsが作るファイルをどのドライブ:ディレクトリに書き出すかを指定しま
  145.  す。
  146.   指定の仕方はMS-DOSの方法です。
  147.   この指定は省略することができます。省略されると、起動時のカレント・デ
  148.  ィレクトリにファイルを書き出します。
  149.    ディレクトリ名の最後に「\」を付ける必要はありません。
  150.    この部分にRAMディスクを指定すると、少し高速になります。
  151.  
  152.  
  153. 4.CTsが作るファイルについて。
  154.  (1) comtree.tmp   コメントツリーの諸データが書き込まれます。
  155.   このデータは、3行が1セットになって、3行で1つの発言についてのデー
  156.  タを表します。
  157.   そして、「comtree0.tmp」に書き出される標題だけのデータや、「comtxt.t
  158.  mp」に書き出される発言の本体と、同じ順番で書き出されています。
  159.    その内容は次のようになっています。
  160.  
  161.    1行目はフォーラム名の行(NIFTYの形式)が入ります。
  162.      以後フォーラム名が変わる場合は、「フォーラム名変更」という文字列
  163.    が入ります。会議室番号は入りません。
  164.     以後会議室番号が変わる場合は、「会議室名変更」という文字列が入り
  165.    ます。会議室番号は入りません。
  166.  
  167.    2行目は、発言に関するデータが入ります。その意味は下の通りです。
  168.        "%5ld %5ld %8ld %8ld %5d %5d %10ld\n"
  169.         | |  | |  | | ↓
  170.         | |  | |  | ↓ 発言日時(10文字の数字)
  171.         | |  | |  ↓ 発言の終了行(5文字の数字)
  172.         | |  | ↓  発言の開始行(5文字の数字)
  173.         | |  ↓ 発言の終了バイト数(8文字の数字)
  174.         | ↓  発言の開始バイト数(8文字の数字)
  175.         ↓ コメント元番号(5文字の数字)
  176.         発言番号(5文字の数字)
  177.       「フォーラム名変更」「会議室名変更」の場合は、それぞれ該当の名前
  178.     が入ります。
  179.  
  180.    3行目は発言のあったファイル名がパス名付きで書き出されます。
  181.       「フォーラム名変更」「会議室名変更」の場合は、改行だけです。
  182.  
  183.  (2) comtree0.tmp  コメントツリーの標題が書き込まれます。
  184.   内容は、画面上に表示される文字列をそのままファイルに書き込んだ物です。
  185.   発言のツリーだけを表示すると、どのフォーラムのどの会議室の発言か分か
  186.  りにくいので、それらがわかるデータ(標題)を入れてあります。
  187.  
  188.  (3) comtxt.tmp   発言の本体が書き込まれます。
  189.  
  190.  (4) 会議室.tmp   フォーラムの会議室の一覧が書き込まれます。
  191.   フォーラムの会議室の一覧が書き込まれます。
  192.   形式は、次のようになっています。
  193.    ┌──────────────────────────┐
  194.    │FORUM:xxxxxx                    │
  195.    │<FMフォーラム????館) >    xxxxxx       │
  196.    │番号 発言 (未読)  最新  会議室名        │
  197.    │ 1       1 (   1)   08/21   FAPXの部屋              │
  198.    └──────────────────────────┘
  199.   フォーラムとフォーラムの間には1行の空行があります。
  200.   また、会議室の一覧に当たる文字列がなかった場合、このファイルは作成さ
  201.  れません。
  202.  
  203.  (5) DL.tmp    DLの一覧が書き込まれます。
  204.   DLの一覧が書き込まれます。
  205.   形式は、次のようになっています。
  206.    ┌──────────────────────────┐
  207.    │LIB:xxxxxx                      │
  208.    │<FMフォーラム????館) >    xxxxxx       │
  209.    │番号 総数 登録済 最新  ライブラリ名            │
  210.    │   1     1  (   1)  08/21   FAPX関連                │
  211.    └──────────────────────────┘
  212.   フォーラムとフォーラムの間には1行の空行があります。
  213.   また、DLの一覧に当たる文字列がなかった場合、このファイルは作成さ
  214.  れません。
  215.  
  216.   (6) SYSTEMディレクトリについて
  217.    今回の修正で、ファイルインデックスという考え方を採用しました。これは、
  218.   1つのログファイルに対して1個の<発言情報ファイル>を作る、という考え方
  219.   です。
  220.   ctm.exe 実行時、「-s<DirName>」で指定したディレクトリにファイル名はその
  221.  ままで、拡張子を000~999という数字にしたファイルを作ります。
  222.   そして ctt.exe はそのディレクトリのファイルを参照してコメントツリーを
  223.  作ります。
  224.   また、オプションの指定により、「既読印」を comtree0.tmp に付け加えます
  225.  が、ctl.exe はそのデータの記録に 「-s<DirName>」を参照しています。
  226.   上記のインデックスファイルを一元管理するのが「ct_index.tmp」です。この
  227.  ファイルには各インデックスファイルがどのログファイルのインデックスであるの
  228.  かを記録しています。
  229.  
  230.   「-s<DirName>」オプションによりこのディレクトリが指定されていない場合は、
  231.  インデックスは各ログファイルと同じディレクトリに置かれます。
  232.  
  233.   ファイルはバイナリーファイルになっています。
  234.  
  235.  
  236. 5.実行例
  237.  (1) 実行例1
  238.   「f:\log」にあるファイルを検索してツリーを作る。
  239.   できたファイルは「f:\tmp」に書き出す。
  240.   「comtxt.tmp」を作る。
  241.      ctt -o f:\tmp f:\log
  242.  
  243.  (2) 実行例2
  244.   「f:\log」にあるファイルを検索して、ツリーを作る。
  245.   できたファイルはカレント・ディレクトリに書き出す。
  246.   ただし、「comtxt.tmp」ファイルは作らない。
  247.      ctt -T f:\log
  248.   例1と異なる所はオプション指定を付加していることです。
  249.  
  250.  (3) 実行例3
  251.   「f:\log\ffmhob 」にあるファイルを検索して、ツリーを作る。
  252.   できたファイルは「f:\tmp」に書き出す。
  253.   「comtxt.tmp」ファイルは作らない。
  254.      ctt -o f:\tmp -DT f:\log\ffmhob
  255.  
  256.  (4) 実行例4 → できるだけ高速に処理を行う。
  257.   MS-DOSの環境変数「tmp」にRAMディスクを指定する。
  258.      例えば、「G:」ドライブがRAMディスクだったとすると、システム
  259.     起動時に最初に実行する「autoexec.bat」というバッチファイルに
  260.       set tmp=g:
  261.     という1行を追加しておくと設定できます。
  262.   「-D」オプションを指定する。
  263.    「-T」オプションを指定する。
  264.  
  265.    使い方はだいたい分かっていただいたでしょうか?
  266.  
  267.  
  268. 6.問題点
  269.  (1) とにかく、処理に時間がかかるということです。
  270.    CATLOGで整理したファイルに対して処理を行うと、かなり待たされ
  271.   ます。
  272.  
  273.  (2) かなりたくさんのTMPファイルを作ります。
  274.  
  275.  (3) 実行時、メモリーのヒープ領域を大量に確保します。充分なメモリーが無
  276.   い場合は処理できる発言数が少なくなるばかりか、「発言の数が多くて処理
  277.   できません」というエラーメッセージを出して中断することもあります。
  278.  
  279.  
  280. 7.作成協力者
  281.  以下の方々にご協力いただいて、本プログラムは作られました。
  282.  ここに紹介して感謝の念を表したいと思います。
  283.  
  284.     PEE01244  Yama-chan     さん
  285.     PFG02442  <Nakatani>   さん
  286.    QFH02666 好実      さん
  287.      GFF00430  えんでん    さん
  288.      VFA03257  フェイス    さん
  289.      PED00201  JINX    さん
  290.      HCD01017  猫飛      さん
  291.      HAD01045  SAINT      さん
  292.      PGA01332  -なるチャン-☆ さん
  293.      HAC01216  doubt      さん
  294.      GDH03105  だいへいくん  さん
  295.    GBH00541 DORAGON     さん
  296.    HFB02053 RENCHAN     さん
  297.    JAG00217 てげてげ    さん
  298.    HGE00530 し~なくん   さん
  299.    HGG03505 LRA.    さん
  300.    HAH00313 Omohyoideus   さん
  301.    HGC02275 With    さん
  302.    PEA02634 雅び      さん
  303.  
  304.  
  305. 8.著作権
  306.    本プログラムは飛雪(ひせつ)さんが開発されたCTsをベースにして、
  307.   改版を重ねたものです。
  308.    現在、飛雪さんは Niftyserve を脱会されており、CTsのメンテナン
  309.   スは、私Withがおこなっていますので、要望やバグ報告などは私の方
  310.   へご連絡ください。
  311.  
  312.    また、CTsの使用、配付は自由に行っていただいてかまいませんが、
  313.   トラブルを避けるために、事前に連絡をお願いします。
  314.  
  315.  
  316. 9.何かありましたら。
  317.    NIFTYのフォーラムFRAVの「おきらく・もっぷた~む」の会議室
  318.   に発言されるか、私あてメールを下さい。
  319.  
  320.                                     ) -------   )  ) . _)_  )_  With )
  321.                        岩間 和彦   ( HGC02275  (/(/ (  (_  ( (  --- (
  322.